#### CSE 3203 CT 4 Assignment Roll No: 1903125

Name: Tanvir Mahtab Zihan

**Assignment**: Built a CPU based on following requirements:

- 1. Word Size of CPU = 3
- 2. ALU Operations = ADD, ROL, OR
- 3. Register Number = 5
- 4. Size of RAM = 7
- 5. Word size of ISA and RAM = 16
- 6. CPU Instructions = Branching(JC, JMP), Reg, Imm

#### Solution:

Video Link (Youtube Video Link): <a href="https://youtu.be/Pk5MLBZK9co">https://youtu.be/Pk5MLBZK9co</a>
In the first 7 clock cycle, instructions from ROM were copied to RAM. Then the PCenable pin was turned to 1 and ROM was practically disabled. Instructions from RAM began executing in every clock cycle.

#### Simulator Design:

1. ALU Circuit (Show all circuits except FA circuit)(Marks 5): Check List:







# 2. Register Set Circuit (Top to Bottom all circuits)(5 Marks): Check List:

| Have you added all circuits of Register Set from 1 bit Register to n bit Register to Top Level Register Set Circuit.? | YES |
|-----------------------------------------------------------------------------------------------------------------------|-----|
|                                                                                                                       |     |





## 3. RAM Circuit (Top to Bottom all circuits)(5 Marks): Check List:

| Have you added all circuits of RAM from 1x1 RAM to 1xN RAM to | YES |
|---------------------------------------------------------------|-----|
| MxN RAM?                                                      |     |







### 4. a) ISA (2 Marks) Check List:

| Have you added all ISA of CPU along with its sample machine | YES |
|-------------------------------------------------------------|-----|
| code to be run on CPU?                                      |     |

16 bit ISA with 7 addressable RAM and 5 addressable Register slots. CPU has 3 bit word size.

## ISA (Register Mode):

| Opcode (4 bit) |                               | Register 1      | Register 2      | Unused |
|----------------|-------------------------------|-----------------|-----------------|--------|
| 2 bits         | 2 bits                        | 3 bits          | 3 bits          | 6 bit  |
| 00             | 00 -ADD<br>01 - OR<br>10 -ROL | Ra<br>(000-100) | Rb<br>(000-100) | xxxxxx |

### ISA (Immediate Mode):

| Opcode (4 bit) | Register 1 | Constant | Unused |  |
|----------------|------------|----------|--------|--|
|----------------|------------|----------|--------|--|

| 2 bits | 2 bits                        | 3 bits          | 3 bits  | 6 bit  |
|--------|-------------------------------|-----------------|---------|--------|
| 01     | 00 -ADD<br>01 - OR<br>10 -ROL | Ra<br>(000-100) | 000-111 | XXXXXX |

### ISA (Branching Mode):

| Opcode (4 bit) |                    | Address | Unused   |
|----------------|--------------------|---------|----------|
| 2 bits         | 2 bits             | 3 bits  | 9 bit    |
| 10             | 00 -JMP<br>01 - JC | 000-110 | xxxxxxxx |

Sample Machine Code with assembly code in comments to be run on CPU (You will make a video running this machine code on CPU in order to prove that your CPU is working perfectly)

| Machine Code     | Assembly Code |
|------------------|---------------|
| 0100001101xxxxxx | ADD A1, 5     |
| 0110001001xxxxxx | ROL A1, 1     |
| 0001011001xxxxxx | OR A3, A1     |
| 0100001101xxxxxx | ADD A1, 5     |
| 1001001xxxxxxxxx | JC 1          |
| 0000011001xxxxxx | ADD A3, A1    |
| 0001011000xxxxxx | OR A3, A0     |
| 1000100xxxxxxxxx | JMP 4         |

# b) CPU (Top to Bottom all circuits)(3 Marks): Check List:

| Have you added all circuits of CPU from Program Counter to Control Unit to Top Level CPU Circuit with Output Pins showing contents of ALU, Register Set, RAM etc. (Important for CPU Verification, Check Tutorial Videos for Details)? | YES |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|



